<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>3_props的简写方式</title>
</head>
<body>
  <!-- 准备好一个"容器" -->
  <div id="test1"></div>
  <div id="test2"></div>
  <div id="test3"></div>

  <!-- 引入React核心库 -->
  <script type="text/javascript" src="../js/react.development.js"></script>
  <!-- 引入react-dom，用于支持react操作DOM -->
  <script type="text/javascript" src="../js/react-dom.development.js"></script>
  <!-- 引入babel，用于将jsx转为js -->
  <script type="text/javascript" src="../js/babel.min.js"></script>
  <!-- 引入prop-types，用于对组件标签属性进行限制 -->
  <script type="text/javascript" src="../js/prop-types.js"></script>

  <script type="text/babel">
    // 1.创建组件
    class Person extends React.Component {

      constructor(props) {
        // 构造器是否接收props，是否传递给super，取决于：是否希望在构造器中通过this访问props
        super(props);
        // super();
        console.log('constructor', this.props);
      }
      // 对标签属性进行类型、必要性的限制
      static propTypes = {
        name: PropTypes.string.isRequired,  // 限制name必传，且为字符串
        sex: PropTypes.string,  // 限制sex为字符串
        age: PropTypes.number,  // 限制age为数值
      }
      // 指定默认标签属性值
      static defaultProps = {
        sex: '男', // sex默认值为男
        age: 18 // age默认值为18
      }
      render() {
        const {name, sex, age} = this.props
        // props是只读的
        // this.props.name = 'jack';   // 此行代码会报错，因为props是只读的
        return (
          <ul>
            <li>姓名：{name}</li>
            <li>性别：{sex}</li>
            <li>年龄：{age}</li>
          </ul>
        )
      }
    }

    // 2.渲染组件到页面
    ReactDOM.render(<Person name="jerry" />, document.getElementById('test1'))
  </script>
</body>
</html>
